aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/article/[slug].tsx
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-05-23 14:07:02 +0200
committerArmand Philippot <git@armandphilippot.com>2022-05-23 16:00:13 +0200
commit34e216546151eaf8a0a3cbb0bc8b65dae4c63bf2 (patch)
treebff34f8a1dc65f0559ddf851433f242edb092824 /src/pages/article/[slug].tsx
parent0f8f963ba3eccd7fd94785bf7fb216b6287cec57 (diff)
refactor: reduce the number of data transformation
Diffstat (limited to 'src/pages/article/[slug].tsx')
-rw-r--r--src/pages/article/[slug].tsx43
1 files changed, 7 insertions, 36 deletions
diff --git a/src/pages/article/[slug].tsx b/src/pages/article/[slug].tsx
index 812fffe..2878538 100644
--- a/src/pages/article/[slug].tsx
+++ b/src/pages/article/[slug].tsx
@@ -18,11 +18,8 @@ import {
type NextPageWithLayout,
} from '@ts/types/app';
import { loadTranslation, type Messages } from '@utils/helpers/i18n';
-import useAddClassName from '@utils/hooks/use-add-classname';
-import useAttributes from '@utils/hooks/use-attributes';
import useBreadcrumb from '@utils/hooks/use-breadcrumb';
import usePrism, { type OptionalPrismPlugin } from '@utils/hooks/use-prism';
-import useQuerySelectorAll from '@utils/hooks/use-query-selector-all';
import useReadingTime from '@utils/hooks/use-reading-time';
import useSettings from '@utils/hooks/use-settings';
import { GetStaticPaths, GetStaticProps } from 'next';
@@ -66,12 +63,15 @@ const ArticlePage: NextPageWithLayout<ArticlePageProps> = ({
title,
url: `/article/${slug}`,
});
- const readingTime = useReadingTime(wordsCount || 0, true);
+ const readingTime = useReadingTime(wordsCount, true);
const headerMeta: PageLayoutProps['headerMeta'] = {
author: author?.name,
publication: { date: dates.publication },
- update: dates.update ? { date: dates.update } : undefined,
+ update:
+ dates.update && dates.publication !== dates.update
+ ? { date: dates.update }
+ : undefined,
readingTime,
thematics:
thematics &&
@@ -167,35 +167,6 @@ const ArticlePage: NextPageWithLayout<ArticlePageProps> = ({
'@graph': [webpageSchema, blogSchema, blogPostSchema],
};
- /**
- * Convert the comments list to the right format.
- *
- * @param {Comment[]} list - The comments list.
- * @returns {PageLayoutProps['comments']} - The formatted comments list.
- */
- const getCommentsList = (list: Comment[]): PageLayoutProps['comments'] => {
- return list.map((comment) => {
- const {
- content: commentBody,
- id: commentId,
- meta: commentMeta,
- parentId,
- replies,
- } = comment;
- const { author: commentAuthor, date } = commentMeta;
- const { name, avatar, website: authorUrl } = commentAuthor;
-
- return {
- author: { name, avatar: avatar!.src, url: authorUrl },
- content: commentBody,
- id: commentId,
- publication: date,
- child: getCommentsList(replies),
- parentId,
- };
- });
- };
-
const prismPlugins: OptionalPrismPlugin[] = ['command-line', 'line-numbers'];
const { attributes, className } = usePrism({ plugins: prismPlugins });
const lineNumbersClassName = className
@@ -254,7 +225,7 @@ const ArticlePage: NextPageWithLayout<ArticlePageProps> = ({
bodyClassName={styles.body}
breadcrumb={breadcrumbItems}
breadcrumbSchema={breadcrumbSchema}
- comments={data && getCommentsList(data)}
+ comments={data}
footerMeta={footerMeta}
headerMeta={headerMeta}
id={id as number}
@@ -314,7 +285,7 @@ export const getStaticPaths: GetStaticPaths = async () => {
return {
paths,
- fallback: true,
+ fallback: false,
};
};